package com.ruoyi.project.digital.mapper;

import java.util.List;

import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.ruoyi.project.digital.domain.Pet;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

/**
 * 宠物信息Mapper接口
 *
 * @author ruoyi
 * @date 2023-10-28
 */
public interface PetMapper extends BaseMapper<Pet>
{
    /**
     * 查询宠物信息
     *
     * @param id 宠物信息ID
     * @return 宠物信息
     */
    public Pet selectPetById(Long id);

    /**
     * 查询宠物信息列表
     *
     * @param pet 宠物信息
     * @return 宠物信息集合
     */
    public List<Pet> selectPetList(Pet pet);

    /**
     * 新增宠物信息
     *
     * @param pet 宠物信息
     * @return 结果
     */
    public int insertPet(Pet pet);

    /**
     * 修改宠物信息
     *
     * @param pet 宠物信息
     * @return 结果
     */
    public int updatePet(Pet pet);

    /**
     * 删除宠物信息
     *
     * @param id 宠物信息ID
     * @return 结果
     */
    public int deletePetById(Long id);

    /**
     * 批量删除宠物信息
     *
     * @param ids 需要删除的数据ID
     * @return 结果
     */
    public int deletePetByIds(Long[] ids);

    @Select("select ${ew.sqlSelect} FROM\n" +
            "\tt_pet t\n" +
            "LEFT JOIN t_mood_pet pt ON pt.pet_id = t.ID ${ew.customSqlSegment}")
    Pet selectPetByMoodId(@Param("ew") Wrapper<Pet> wrapper);
}
